<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>
    <h2>Proxy实现绑定</h2>
    <input type="text" id="inp">
    <div class="txt"></div>
</body>
<script>
    const obj={}
    const inp=document.querySelector('#inp')

    // Object.defineProperty(obj,'prop',{
    //     get() {
    //         return val;
    //     },
    //     set(newV) {
    //         console.log('新值：',newV)
    //         val=newV;
    //         document.querySelector('.txt').textContent=val;
    //     }
    // })

    // inp.addEventListener('keyup',function(e) {
    //     console.log(e.target.value)
    //     obj.prop=e.target.value
    // },false)

    const p=new Proxy(obj,{
        get(target,key,receiver) {
            return target[key]
        },
        set(target,key,value,receiver) {
            target[key]=value;
            document.querySelector('.txt').textContent=target[key];
        }
    })


      inp.addEventListener('keyup',function(e) {
        console.log(e.target.value)
        p['prop']=e.target.value
    },false)
</script>
</html>